mysql

推荐列表 站点导航

当前位置:首页 > 数据库 > mysql >

MySQL笔记之触发器的应用

来源:网络整理  作者:网络  发布时间:2020-12-08 08:11
创建触发器 创建只有一个执行语句的触发器 复制代码 代码如下: CREATE TRIGGER 触发器名 BEFORE|AFTER 触发事件 ON 表名 F...
创建触发器   创建只有一个执行语句的触发器   复制代码 代码如下:     CREATE TRIGGER 触发器名 BEFORE|AFTER 触发事件 ON 表名 FOR EACH ROW 执行语句     其中,触发器名参数指要创建的触发器的名字 BEFORE和AFTER参数指定了触发执行的时间,在事件之前或是之后   FOR EACH ROW表示任何一条记录上的操作满足触发事件都会触发该触发器   复制代码 代码如下:     mysql> CREATE TRIGGER trig1 AFTER INSERT -> ON work FOR EACH ROW -> INSERT INTO time VALUES(NOW()); Query OK, 0 rows affected (0.09 sec)     上面创建了一个名为trig1的触发器,一旦在work中有插入动作,就会自动往time表里插入当前时间   创建有多个执行语句的触发器   复制代码 代码如下:     CREATE TRIGGER 触发器名 BEFORE|AFTER 触发事件 ON 表名 FOR EACH ROW BEGIN 执行语句列表 END     其中,BEGIN与END之间的执行语句列表参数表示需要执行的多个语句,不同语句用分号隔开 tips:一般情况下,mysql默认是以 ; 作为结束执行语句,与触发器中需要的分行起冲突      为解决此问题可用DELIMITER,如:DELIMITER ||,可以将结束符号变成||      当触发器创建完成后,可以用DELIMITER ;来将结束符号变成;   复制代码 代码如下:     mysql> DELIMITER || mysql> CREATE TRIGGER trig2 BEFORE DELETE -> ON work FOR EACH ROW -> BEGIN -> INSERT INTO time VALUES(NOW()); -> INSERT INTO time VALUES(NOW()); -> END -> || Query OK, 0 rows affected (0.06 sec)   mysql> DELIMITER ;     上面的语句中,开头将结束符号定义为||,中间定义一个触发器,一旦有满足条件的删除操作 就会执行BEGIN和END中的语句,接着使用||结束   最后使用DELIMITER ; 将结束符号还原     查看触发器 SHOW TRIGGERS语句查看触发器信息   复制代码 代码如下:     mysql> SHOW TRIGGERS\G; *************************** 1. row *************************** Trigger: trig1 Event: INSERT Table: work Statement: INSERT INTO time VALUES(NOW()) Timing: AFTER Created: NULL sql_mode:  Definer: root@localhost character_set_client: utf8 collation_connection: utf8_general_ci Database Collation: latin1_swedish_ci     结果会显示所有触发器的基本信息 tips:SHOW TRIGGERS语句无法查询指定的触发器     在triggers表中查看触发器信息   复制代码 代码如下:     mysql> SELECT * FROM information_schema.triggers\G *************************** 1. row *************************** TRIGGER_CATALOG: def TRIGGER_SCHEMA: person TRIGGER_NAME: trig1 EVENT_MANIPULATION: INSERT EVENT_OBJECT_CATALOG: def EVENT_OBJECT_SCHEMA: person EVENT_OBJECT_TABLE: work ACTION_ORDER: 0 ACTION_CONDITION: NULL ACTION_STATEMENT: INSERT INTO time VALUES(NOW())     结果显示了所有触发器的详细信息,同时,该方法可以查询制定触发器的详细信息 复制代码 代码如下:     mysql> SELECT * FROM information_schema.triggers WHERE TRIGGER_NAME='trig1'\G *************************** 1. row *************************** TRIGGER_CATALOG: def TRIGGER_SCHEMA: person TRIGGER_NAME: trig1 EVENT_MANIPULATION: INSERT EVENT_OBJECT_CATALOG: def EVENT_OBJECT_SCHEMA: person EVENT_OBJECT_TABLE: work     tips:所有触发器信息都存储在information_schema数据库下的triggers表中    可以使用SELECT语句查询,如果触发器信息过多,最好通过TRIGGER_NAME字段指定查询     删除触发器   复制代码 代码如下:     mysql> DROP TRIGGER trig1; Query OK, 0 rows affected (0.04 sec)     删除触发器之后最好使用上面的方法查看一遍 同时,也可以使用database.trig来指定某个数据库中的触发器   tips:如果不需要某个触发器时一定要将这个触发器删除,以免造成意外操作  

相关热词: MYSQL

本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供用于网络技术学习参考,学习中请遵循相关法律法规!

本文地址: https://v30.fanwenzhu.com/sql/mysql/1348.shtml

最新文章
 这些文件如果在configure命 这些文件如果在configure命

时间:2021-01-22

说明在数据库崩溃时内存 说明在数据库崩溃时内存

时间:2021-01-22

破解极验(geetest)验证码 破解极验(geetest)验证码

时间:2021-01-22

今天这种代码阅读方法仍 今天这种代码阅读方法仍

时间:2021-01-22

 count(*) as cnt from sakila.fi count(*) as cnt from sakila.fi

时间:2021-01-22

 可能你注意到系统提示的 可能你注意到系统提示的

时间:2021-01-22

搭建环境与运行 搭建环境与运行

时间:2021-01-22

MySQL主从复制的常见拓扑 MySQL主从复制的常见拓扑

时间:2021-01-22

Copyright © www.juheyunku.com      关于 | 合作 | 声明 | 联系 | 更新 | 地图 | Tags

MySQL笔记之触发器的应用

2020-12-08 编辑:网络

创建触发器   创建只有一个执行语句的触发器   复制代码 代码如下:     CREATE TRIGGER 触发器名 BEFORE|AFTER 触发事件 ON 表名 FOR EACH ROW 执行语句     其中,触发器名参数指要创建的触发器的名字 BEFORE和AFTER参数指定了触发执行的时间,在事件之前或是之后   FOR EACH ROW表示任何一条记录上的操作满足触发事件都会触发该触发器   复制代码 代码如下:     mysql> CREATE TRIGGER trig1 AFTER INSERT -> ON work FOR EACH ROW -> INSERT INTO time VALUES(NOW()); Query OK, 0 rows affected (0.09 sec)     上面创建了一个名为trig1的触发器,一旦在work中有插入动作,就会自动往time表里插入当前时间   创建有多个执行语句的触发器   复制代码 代码如下:     CREATE TRIGGER 触发器名 BEFORE|AFTER 触发事件 ON 表名 FOR EACH ROW BEGIN 执行语句列表 END     其中,BEGIN与END之间的执行语句列表参数表示需要执行的多个语句,不同语句用分号隔开 tips:一般情况下,mysql默认是以 ; 作为结束执行语句,与触发器中需要的分行起冲突      为解决此问题可用DELIMITER,如:DELIMITER ||,可以将结束符号变成||      当触发器创建完成后,可以用DELIMITER ;来将结束符号变成;   复制代码 代码如下:     mysql> DELIMITER || mysql> CREATE TRIGGER trig2 BEFORE DELETE -> ON work FOR EACH ROW -> BEGIN -> INSERT INTO time VALUES(NOW()); -> INSERT INTO time VALUES(NOW()); -> END -> || Query OK, 0 rows affected (0.06 sec)   mysql> DELIMITER ;     上面的语句中,开头将结束符号定义为||,中间定义一个触发器,一旦有满足条件的删除操作 就会执行BEGIN和END中的语句,接着使用||结束   最后使用DELIMITER ; 将结束符号还原     查看触发器 SHOW TRIGGERS语句查看触发器信息   复制代码 代码如下:     mysql> SHOW TRIGGERS\G; *************************** 1. row *************************** Trigger: trig1 Event: INSERT Table: work Statement: INSERT INTO time VALUES(NOW()) Timing: AFTER Created: NULL sql_mode:  Definer: root@localhost character_set_client: utf8 collation_connection: utf8_general_ci Database Collation: latin1_swedish_ci     结果会显示所有触发器的基本信息 tips:SHOW TRIGGERS语句无法查询指定的触发器     在triggers表中查看触发器信息   复制代码 代码如下:     mysql> SELECT * FROM information_schema.triggers\G *************************** 1. row *************************** TRIGGER_CATALOG: def TRIGGER_SCHEMA: person TRIGGER_NAME: trig1 EVENT_MANIPULATION: INSERT EVENT_OBJECT_CATALOG: def EVENT_OBJECT_SCHEMA: person EVENT_OBJECT_TABLE: work ACTION_ORDER: 0 ACTION_CONDITION: NULL ACTION_STATEMENT: INSERT INTO time VALUES(NOW())     结果显示了所有触发器的详细信息,同时,该方法可以查询制定触发器的详细信息 复制代码 代码如下:     mysql> SELECT * FROM information_schema.triggers WHERE TRIGGER_NAME='trig1'\G *************************** 1. row *************************** TRIGGER_CATALOG: def TRIGGER_SCHEMA: person TRIGGER_NAME: trig1 EVENT_MANIPULATION: INSERT EVENT_OBJECT_CATALOG: def EVENT_OBJECT_SCHEMA: person EVENT_OBJECT_TABLE: work     tips:所有触发器信息都存储在information_schema数据库下的triggers表中    可以使用SELECT语句查询,如果触发器信息过多,最好通过TRIGGER_NAME字段指定查询     删除触发器   复制代码 代码如下:     mysql> DROP TRIGGER trig1; Query OK, 0 rows affected (0.04 sec)     删除触发器之后最好使用上面的方法查看一遍 同时,也可以使用database.trig来指定某个数据库中的触发器   tips:如果不需要某个触发器时一定要将这个触发器删除,以免造成意外操作  

本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供学习参考!
本文地址为 https://v30.fanwenzhu.com/sql/mysql/1348.shtml

相关文章

风云图片

推荐阅读

返回mysql频道首页